$(function(){

	// 打开登录框
	$('.login_btn').click(function(){
        $('.login_form_con').show();
	})
	
	// 点击关闭按钮关闭登录框或者注册框
	$('.shutoff').click(function(){
		$(this).closest('form').hide();
	})

    // 隐藏错误
    $(".login_form #mobile").focus(function(){
        $("#login-mobile-err").hide();
    });
    $(".login_form #password").focus(function(){
        $("#login-password-err").hide();
    });

    $(".register_form #mobile").focus(function(){
        $("#register-mobile-err").hide();
    });
    $(".register_form #imagecode").focus(function(){
        $("#register-image-code-err").hide();
    });
    $(".register_form #smscode").focus(function(){
        $("#register-sms-code-err").hide();
    });
    $(".register_form #password").focus(function(){
        $("#register-password-err").hide();
    });


	// 点击输入框，提示文字上移
	// $('.form_group').on('click focusin',function(){
	// 	$(this).children('.input_tip').animate({'top':-5,'font-size':12},'fast').siblings('input').focus().parent().addClass('hotline');
	// })
    $('.form_group').on('click',function(){
    $(this).children('input').focus()
    })

    $('.form_group input').on('focusin',function(){
        $(this).siblings('.input_tip').animate({'top':-5,'font-size':12},'fast')
        $(this).parent().addClass('hotline');
    })

	// 输入框失去焦点，如果输入框为空，则提示文字下移
	$('.form_group input').on('blur focusout',function(){
		$(this).parent().removeClass('hotline');
		var val = $(this).val();
		if(val=='')
		{
			$(this).siblings('.input_tip').animate({'top':22,'font-size':14},'fast');
		}
	})


	// 打开注册框
	$('.register_btn').click(function(){
		$('.register_form_con').show();
		generateImageCode()
	})


	// 登录框和注册框切换
	$('.to_register').click(function(){
		$('.login_form_con').hide();
		$('.register_form_con').show();
        generateImageCode()
	})

	// 登录框和注册框切换
	$('.to_login').click(function(){
		$('.login_form_con').show();
		$('.register_form_con').hide();
	})

	// 根据地址栏的hash值来显示用户中心对应的菜单
	var sHash = window.location.hash;
	if(sHash!=''){
		var sId = sHash.substring(1);
		var oNow = $('.'+sId);		
		var iNowIndex = oNow.index();
		$('.option_list li').eq(iNowIndex).addClass('active').siblings().removeClass('active');
		oNow.show().siblings().hide();
	}

	// 用户中心菜单切换
	var $li = $('.option_list li');
	var $frame = $('#main_frame');

	$li.click(function(){
		if($(this).index()==5){
			$('#main_frame').css({'height':900});
		}
		else{
			$('#main_frame').css({'height':660});
		}
		$(this).addClass('active').siblings().removeClass('active');
		$(this).find('a')[0].click()
	});

    // TODO 登录表单提交
    $(".login_form_con").submit(function (e) {
        e.preventDefault();
        var mobile = $(".login_form #mobile").val();
        var password = $(".login_form #password").val();

        if (!mobile) {
            $("#login-mobile-err").show();
            return;
        }

        if (!password) {
            $("#login-password-err").show();
            return;
        }

        // 发起登录请求
         var params = {
             // 发送参数
             "mobile":mobile,
             "password":password
          };
          $.ajax({
                     url:"/passport/login",
                     type:"post",
                     dataType:"json",
                     data:JSON.stringify(params),
                     headers:{
                         "X-CSRFToken":getCookie("csrf_token")
                     },
                     // 请求参数的数据类型
                     contentType: "application/json"
                 }).done(function(response){
                     // 请求成功
                     if(response.errno == "0"){
                         // 登录成功
                         // 刷新页面
                         location.reload()

                     }else {
                         $("#login-password-err").html("账号或密码错误");
                         $("#login-password-err").show();
                     }

                 })

    });


    // TODO 注册按钮点击
    $(".register_form_con").submit(function (e) {
        // 阻止默认提交操作
        e.preventDefault();

		// 取到用户输入的内容
        var mobile = $("#register_mobile").val();
        var smscode = $("#smscode").val();
        var password = $("#register_password").val();

		if (!mobile) {
            $("#register-mobile-err").show();
            return;
        }
        if (!smscode) {
            $("#register-sms-code-err").show();
            return;
        }
        if (!password) {
            $("#register-password-err").html("请填写密码!");
            $("#register-password-err").show();
            return;
        }

		if (password.length < 6) {
            $("#register-password-err").html("密码长度不能少于6位");
            $("#register-password-err").show();
            return;
        }

        // TODO 发起注册请求
         var params = {
             // 发送参数
             "mobile":mobile,
             "smscode":smscode,
             "password":password
          };
          $.ajax({
                     url:"/passport/register",
                     type:"post",
                     dataType:"json",
                     data:JSON.stringify(params),
                      headers:{
                                 "X-CSRFToken":getCookie("csrf_token")
                             },
                     // 请求参数的数据类型
                     contentType: "application/json"
                 }).done(function(response){
                     // 请求成功
                    if (response.errno == '0'){
                        // 注册成功
                        //刷新页面
                        location.reload();

                    }else{
                        // 注册失败
                       $("#register-password-err").html("验证码错误或已过期");
                       $("#register-password-err").show();
                    }

                 })



    })
})

var imageCodeId = ""

//  生成一个图片验证码的编号，并设置页面中图片验证码img标签的src属性
function generateImageCode() {
    // UUID 通用唯一标识符
    // 浏览器发起图片验证码请求/image_code?imageCodeId=xxxxxx
    imageCodeId = generateUUID()
    // 生成url
    var url = "/passport/image_code?imageCodeId="+imageCodeId
    // 给指定的img标签设置src,image标签就会去想这个地址发起请求,请求图片
    $(".get_pic_code").attr("src",url)

}

// 发送短信验证码
function sendSMSCode() {
    // 校验参数，保证输入框有数据填写
    $(".get_code").removeAttr("onclick");
    var mobile = $("#register_mobile").val();
    if (!mobile) {
        $("#register-mobile-err").html("请填写正确的手机号！");
        $("#register-mobile-err").show();
        $(".get_code").attr("onclick", "sendSMSCode();");
        return;
    }
    var imageCode = $("#imagecode").val();
    if (!imageCode) {
        $("#image-code-err").html("请填写验证码！");
        $("#image-code-err").show();
        $(".get_code").attr("onclick", "sendSMSCode();");
        return;
    }

    // 发送短信验证码

    var params = {"mobile":mobile,
                    "image_code":imageCode,
                    "image_code_id":imageCodeId
                };
     $.ajax({
                url:"/passport/sms_code",
                type:"post",
                dataType:"json",
                data:JSON.stringify(params),
                headers:{
                         "X-CSRFToken":getCookie("csrf_token")
                     },
                // 请求参数的数据类型
                contentType: "application/json"
            }).done(function(response){
                if (response.errno == "0"){
                    // 代表发送成功
                    var num = 60;
                    var timer = setInterval(function () {
                        if (num==1){
                            // 倒计时结束
                            clearInterval(timer);
                            // 设置显示内容
                            timer = null;
                            $(".get_code").html("点击获取验证码");
                            // 添加点击事件
                            $(".get_code").attr("onclick", "sendSMSCode();");
                        }else{
                           num -= 1;
                           // 设置a标签内容
                            str = num + "秒后重试";
                            $(".get_code").html(str);

                            }

                        },1000)
                    }else {
                    // 发送失败
                    alert(response.errmsg);
                    $("#image-code-err").html("验证码错误！");
                    $("#image-code-err").show();
                    $(".get_code").attr("onclick", "sendSMSCode();");

                    }

            })
            .fail(function(){
                alert('服务器超时，请重试！');
                $(".get_code").attr("onclick", "sendSMSCode();")
            })
}

// 调用该函数模拟点击左侧按钮
function fnChangeMenu(n) {
    var $li = $('.option_list li');
    if (n >= 0) {
        $li.eq(n).addClass('active').siblings().removeClass('active');
        // 执行 a 标签的点击事件
        $li.eq(n).find('a')[0].click()
    }
}

// 退出请求
function logout () {
  $.ajax({
             url:"/passport/logout",
             type:"get",
             dataType:"json"
         }).done(function(response){
             // 请求成功
            location.reload()

         })
}

// 一般页面的iframe的高度是660
// 新闻发布页面iframe的高度是900
function fnSetIframeHeight(num){
	var $frame = $('#main_frame');
	$frame.css({'height':num});
}

function getCookie(name) {
    var r = document.cookie.match("\\b" + name + "=([^;]*)\\b");
    return r ? r[1] : undefined;
}

function generateUUID() {
    var d = new Date().getTime();
    if(window.performance && typeof window.performance.now === "function"){
        d += performance.now(); //use high-precision timer if available
    }
    var uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
        var r = (d + Math.random()*16)%16 | 0;
        d = Math.floor(d/16);
        return (c=='x' ? r : (r&0x3|0x8)).toString(16);
    });
    return uuid;
}
